Skill
আনসিবল (Ansible)

রোল এবং রিইউজেবল কোড

Latest Technologies - আনসিবল (Ansible) - NCTB BOOK

Ansible এ রোল (Role) হলো প্লেবুকের কোডকে সংগঠিত এবং পুনরায় ব্যবহারযোগ্য (Reusable) করার জন্য একটি স্ট্যান্ডার্ড উপায়। রোল ব্যবহার করলে আপনি একটি স্ট্রাকচার্ড ফরম্যাটে কোড লেখার সুবিধা পান, যা বড় প্লেবুকগুলোকে ছোট ছোট অংশে ভাগ করে সহজে ব্যবস্থাপনা করা যায়। এতে কোডের পুনরায় ব্যবহারযোগ্যতা বাড়ে এবং রক্ষণাবেক্ষণ করা সহজ হয়।

রোল (Role) এর মূল ধারণা

রোল মূলত Ansible প্লেবুকের কোড এবং ফাইলগুলিকে একটি স্ট্রাকচার্ড ডিরেক্টরিতে সাজানোর একটি পদ্ধতি। রোল ব্যবহার করে, আপনি এক বা একাধিক কাজ বা কনফিগারেশনকে একটি স্ট্যান্ডার্ড ফরম্যাটে প্যাকেজ করতে পারেন, যা সহজে পুনরায় ব্যবহার করা যায়।

রোলের ডিরেক্টরি স্ট্রাকচার

রোলগুলোতে একটি নির্দিষ্ট ডিরেক্টরি স্ট্রাকচার ফলো করতে হয়, যাতে কোডটি সংরক্ষণ, সংগঠিত, এবং অ্যাক্সেস করা সহজ হয়। নিচে একটি রোলের স্ট্যান্ডার্ড স্ট্রাকচার দেখানো হয়েছে:

roles/
└── my_role/
    ├── tasks/
    │   └── main.yml
    ├── handlers/
    │   └── main.yml
    ├── templates/
    ├── files/
    ├── vars/
    │   └── main.yml
    ├── defaults/
    │   └── main.yml
    ├── meta/
    │   └── main.yml
    └── README.md

রোলের প্রতিটি উপাদান

১. tasks/: এখানে রোলের মূল টাস্কগুলো থাকে, যা সাধারণত main.yml ফাইলের মধ্যে সংরক্ষণ করা হয়। ২. handlers/: হ্যান্ডলারগুলো সংরক্ষণ করা হয়, যা টাস্কে ব্যবহার করা হয়। ৩. templates/: Jinja2 টেমপ্লেট ফাইল রাখা হয়, যা ডায়নামিক কনফিগারেশন তৈরি করতে ব্যবহৃত হয়। 4. files/: কপি বা ব্যবহারের জন্য স্থির ফাইল (static files) সংরক্ষণ করা হয়। 5. vars/: রোলের জন্য নির্দিষ্ট ভ্যারিয়েবল সংরক্ষণ করা হয়। 6. defaults/: ডিফল্ট ভ্যারিয়েবলগুলো এখানে সংরক্ষণ করা হয়, যেগুলি সহজেই ওভাররাইড করা যায়। 7. meta/: এখানে রোলের মেটাডাটা (যেমন ডিপেন্ডেন্সি) থাকে। 8. README.md: রোলের জন্য ডকুমেন্টেশন থাকে।

একটি সাধারণ রোলের উদাহরণ

ধরা যাক, আমরা একটি apache নামক রোল তৈরি করতে চাই, যা Apache ওয়েব সার্ভার ইনস্টল এবং কনফিগার করবে।

 

# roles/apache/tasks/main.yml
---
- name: Install Apache
  apt:
    name: apache2
    state: present
  notify: Start Apache

- name: Copy Apache configuration
  template:
    src: apache.conf.j2
    dest: /etc/apache2/sites-available/000-default.conf
  notify: Reload Apache

 

# roles/apache/handlers/main.yml
---
- name: Start Apache
  service:
    name: apache2
    state: started
    enabled: yes

- name: Reload Apache
  service:
    name: apache2
    state: reloaded

 

# roles/apache/vars/main.yml
---
apache_port: 80

রোল ব্যবহার করা প্লেবুকে

রোল তৈরি করার পর, প্লেবুকে সহজেই তা অন্তর্ভুক্ত করা যায়:

 

---
- name: Deploy Apache server
  hosts: webservers
  become: yes
  roles:
    - apache

এই প্লেবুকটি webservers হোস্ট গ্রুপে apache রোল প্রয়োগ করবে।

রিইউজেবল কোড (Reusable Code)

রোল Ansible এ কোডকে পুনরায় ব্যবহারযোগ্য করার অন্যতম সহজ উপায়। কিছু কৌশল যা রোলকে রিইউজেবল এবং ফ্লেক্সিবল করে তোলে:

  1. ভ্যারিয়েবল ব্যবহার: রোলের ভ্যারিয়েবলগুলোকে defaults বা vars ডিরেক্টরিতে সংরক্ষণ করে। এগুলিকে প্লেবুকের মাধ্যমে ওভাররাইড করা যায়, যা রোলকে বিভিন্ন কনফিগারেশনে ব্যবহার করা সহজ করে।
  2. টেমপ্লেট ব্যবহার: Jinja2 টেমপ্লেট ব্যবহার করে আপনি ডায়নামিক কনফিগারেশন তৈরি করতে পারেন, যা একাধিক সিস্টেমে একই রোল প্রয়োগের সময় সহজে কাস্টমাইজ করা যায়।
  3. রোলের ডিপেন্ডেন্সি ডিফাইন করা: meta/main.yml ফাইলের মাধ্যমে একটি রোলের জন্য কোন রোলগুলির ডিপেন্ডেন্সি আছে তা ডিফাইন করা যায়, যা রোলগুলোর মধ্যে সম্পর্ক তৈরি করে।

 

# roles/apache/meta/main.yml
---
dependencies:
  - { role: common, some_variable: some_value }

রোল এবং রিইউজেবিলিটির সুবিধা

  • Modularity: প্লেবুকের কোডকে ছোট ছোট অংশে ভাগ করে কাজকে সহজ এবং সুসংগঠিত করা।
  • Reusability: একবার একটি রোল তৈরি করলে, আপনি সেটি বারবার ব্যবহার করতে পারেন এবং অন্য প্রোজেক্টেও সহজে ইম্পোর্ট করতে পারেন।
  • Maintainability: কোড স্ট্রাকচার্ড হওয়ার কারণে, কোনো পরিবর্তন বা আপডেট সহজে করা যায়।
  • Scalability: বড় প্লেবুক বা সিস্টেমের ক্ষেত্রে রোল ব্যবহার করলে সহজে স্কেল করা যায়।

সংক্ষেপে:

  • রোল হলো প্লেবুকের কোডকে সংগঠিত এবং পুনরায় ব্যবহারযোগ্য করার জন্য Ansible এর একটি স্ট্যান্ডার্ড উপায়।
  • ডিরেক্টরি স্ট্রাকচার: প্রতিটি রোলের একটি নির্দিষ্ট ডিরেক্টরি স্ট্রাকচার আছে যা কোড সংগঠিত করে।
  • রোল ব্যবহার করলে প্লেবুকের মডুলারিটি, পুনরায় ব্যবহারযোগ্যতা, এবং রক্ষণাবেক্ষণ সহজ হয়।

এইভাবে রোল এবং রিইউজেবল কোড ব্যবহার করে Ansible প্লেবুকের কার্যকারিতা, দক্ষতা, এবং সংগঠন আরও উন্নত করা সম্ভব।

রোল কী এবং এর ব্যবহার

Ansible এ রোল (Role) হলো একটি সংগঠিত উপায়ে প্লেবুকের টাস্ক, ফাইল, টেমপ্লেট, ভ্যারিয়েবল, এবং অন্যান্য উপাদান গুছিয়ে রাখার একটি পদ্ধতি। রোল ব্যবহার করে আপনি একটি মডুলার এবং পুনরায় ব্যবহারযোগ্য প্লেবুক তৈরি করতে পারেন, যা বড় এবং জটিল ইনফ্রাস্ট্রাকচার ম্যানেজমেন্ট সহজ করে তোলে।

রোল কীভাবে কাজ করে?

রোল হলো একটি ডিরেক্টরি স্ট্রাকচার, যেখানে Ansible এর বিভিন্ন উপাদান যেমন টাস্ক, ভ্যারিয়েবল, টেমপ্লেট, ফাইল, এবং হ্যান্ডলার গুছিয়ে রাখা হয়। এটি বড় প্রজেক্ট বা ইনফ্রাস্ট্রাকচারে কোড পুনরায় ব্যবহারযোগ্য এবং সহজে মেইনটেইনেবল করে।

রোল কেন ব্যবহার করা হয়?

  1. কোড পুনরায় ব্যবহারযোগ্যতা: একবার একটি রোল তৈরি করে সেটি বিভিন্ন প্লেবুকে সহজেই ব্যবহার করা যায়।
  2. স্ট্রাকচার্ড প্লেবুক: রোলের মাধ্যমে প্লেবুকের কোড এবং উপাদানগুলোকে গুছিয়ে রাখা যায়, যা বড় প্রজেক্টে কাজ করার সময় সুবিধাজনক।
  3. সহজ মেইনটেনেন্স: রোলের মাধ্যমে প্লেবুক গুছিয়ে রাখলে, কোড পরিবর্তন বা আপডেট করা সহজ হয়।
  4. সহজ শেয়ারিং: রোলগুলো এক্সপোর্ট এবং শেয়ার করা সহজ, যাতে টিমের অন্যান্য সদস্যরা সেগুলো ব্যবহার করতে পারেন।
  5. স্ট্যান্ডার্ডাইজেশন: রোল ব্যবহার করে ইনফ্রাস্ট্রাকচার সেটআপ এবং কনফিগারেশনে স্ট্যান্ডার্ড প্র্যাকটিস মেনে চলা যায়।

রোলের স্ট্রাকচার

Ansible এ রোলের একটি নির্দিষ্ট ডিরেক্টরি স্ট্রাকচার রয়েছে যা নিচে দেখানো হলো:

roles/
└── my_role/
    ├── defaults/
    │   └── main.yml
    ├── files/
    ├── handlers/
    │   └── main.yml
    ├── meta/
    │   └── main.yml
    ├── tasks/
    │   └── main.yml
    ├── templates/
    ├── tests/
    ├── vars/
    │   └── main.yml

প্রতিটি ডিরেক্টরির ভূমিকা

  • defaults/: এখানে ডিফল্ট ভ্যারিয়েবলগুলো রাখা হয়। এগুলো সবচেয়ে কম প্রায়োরিটি পায় এবং সহজেই ওভাররাইড করা যায়।
  • files/: এখানে সাধারণ ফাইল রাখা হয়, যা প্লেবুকে কপি বা ব্যবহারের জন্য ব্যবহার করা হয়।
  • handlers/: এখানে হ্যান্ডলার সংজ্ঞায়িত করা হয়, যা নির্দিষ্ট টাস্ক শেষ হওয়ার পর চালানো হয় (যেমন: সার্ভিস রিস্টার্ট করা)।
  • meta/: মেটাডেটা সম্পর্কিত তথ্য রাখা হয়, যেমন রোলের ডিপেন্ডেন্সি বা কপিরাইট ইনফরমেশন।
  • tasks/: এখানে টাস্কগুলো রাখা হয়। main.yml হলো রোলের প্রধান টাস্ক ফাইল।
  • templates/: টেমপ্লেট ফাইল (Jinja2) রাখা হয়, যা প্লেবুক রান করার সময় রেন্ডার করা হয়।
  • vars/: এখানে ভ্যারিয়েবলগুলো সংজ্ঞায়িত করা হয়। এগুলোর প্রায়োরিটি বেশি এবং সহজে ওভাররাইড হয় না।

রোল ব্যবহার করার উদাহরণ

ধরা যাক, আমরা একটি রোল তৈরি করতে চাই যা Apache সার্ভার ইনস্টল এবং কনফিগার করবে।

  1. রোল তৈরি করা:

 

ansible-galaxy init my_apache_role

এটি একটি রোল তৈরি করবে roles/my_apache_role ডিরেক্টরির অধীনে, যেখানে পূর্বে বর্ণিত সমস্ত ডিরেক্টরি স্বয়ংক্রিয়ভাবে তৈরি হবে।

  1. টাস্ক ডিফাইন করা (tasks/main.yml):

 

---
- name: Install Apache
  apt:
    name: apache2
    state: present

- name: Start Apache service
  service:
    name: apache2
    state: started
    enabled: yes
  1. হ্যান্ডলার ডিফাইন করা (handlers/main.yml):

 

---
- name: restart apache
  service:
    name: apache2
    state: restarted
  1. প্লেবুকে রোল অন্তর্ভুক্ত করা (site.yml):

 

---
- hosts: webservers
  become: yes
  roles:
    - my_apache_role

এখানে, প্লেবুকের roles সেকশনে my_apache_role অন্তর্ভুক্ত করা হয়েছে, যা Apache ইনস্টল এবং কনফিগার করবে।

সংক্ষেপে

Ansible এ রোল হলো একটি সংগঠিত এবং পুনরায় ব্যবহারযোগ্য উপায়ে প্লেবুক এবং তার বিভিন্ন উপাদান গুছিয়ে রাখার একটি পদ্ধতি। এটি বড় প্রজেক্টে কোড মডুলার, স্ট্রাকচার্ড এবং পুনরায় ব্যবহারযোগ্য রাখতে সাহায্য করে।

রোলের ডিরেক্টরি স্ট্রাকচার

Ansible রোল (Role) হলো একটি সংগঠিত পদ্ধতি যেখানে টাস্ক, হ্যান্ডলার, ভ্যারিয়েবল, টেম্পলেট, এবং অন্যান্য ফাইলগুলো একটি নির্দিষ্ট কাঠামোতে সাজানো হয়। রোল ব্যবহার করে আপনার প্লেবুকগুলিকে পুনরায় ব্যবহারযোগ্য এবং সহজে পরিচালনাযোগ্য করা যায়। Ansible রোলের একটি নির্দিষ্ট ডিরেক্টরি স্ট্রাকচার আছে যা মেনে চলা উচিত, যাতে Ansible সঠিকভাবে রোল খুঁজে পায় এবং ব্যবহার করতে পারে।

Ansible রোলের ডিরেক্টরি স্ট্রাকচার

একটি Ansible রোলের সাধারণ ডিরেক্টরি স্ট্রাকচার নিচের মতো হয়:

 

roles/
└── /
    ├── defaults/
    │   └── main.yml
    ├── files/
    ├── handlers/
    │   └── main.yml
    ├── meta/
    │   └── main.yml
    ├── tasks/
    │   └── main.yml
    ├── templates/
    ├── tests/
    │   ├── inventory
    │   └── test.yml
    ├── vars/
    │   └── main.yml
    └── README.md

ডিরেক্টরি এবং ফাইলের বিবরণ

defaults/:

  • এই ডিরেক্টরিতে রোলের ডিফল্ট ভ্যারিয়েবল সংরক্ষিত থাকে।
  • main.yml ফাইলে ডিফল্ট ভ্যারিয়েবলগুলি উল্লেখ করা হয় যা অন্য ভ্যারিয়েবল দ্বারা ওভাররাইড হতে পারে।

files/:

  • এই ডিরেক্টরিতে স্ট্যাটিক ফাইলগুলি সংরক্ষণ করা হয়, যা প্লেবুকে কপি করা বা ব্যবহৃত হতে পারে।
  • উদাহরণ: কনফিগারেশন ফাইল, স্ক্রিপ্ট ইত্যাদি।

handlers/:

  • হ্যান্ডলারগুলো সংরক্ষণ করা হয় যা নির্দিষ্ট অবস্থার উপর ভিত্তি করে টাস্ক শেষ হওয়ার পর চালিত হয়।
  • main.yml ফাইলে হ্যান্ডলারগুলো উল্লেখ করা হয়, যেমন: সার্ভিস রিস্টার্ট করা।

meta/:

  • এই ডিরেক্টরিতে মেটা-ডেটা সংরক্ষণ করা হয়, যা রোল সম্পর্কে তথ্য দেয়।
  • main.yml ফাইলে ডিপেন্ডেন্সি বা রোলের ডিপেন্ডেন্সি উল্লেখ করা যায়।

tasks/:

  • রোলের প্রধান টাস্কগুলো সংরক্ষণ করা হয়।
  • main.yml ফাইল হলো টাস্কের এন্ট্রিপয়েন্ট, যেখানে রোলের সমস্ত টাস্ক উল্লেখ করা হয়। এটি অন্যান্য টাস্ক ফাইলকেও অন্তর্ভুক্ত করতে পারে।

templates/:

  • এই ডিরেক্টরিতে Jinja2 টেম্পলেটগুলো সংরক্ষণ করা হয় যা রোলের অংশ হিসেবে ব্যবহৃত হয়।
  • টেম্পলেট ব্যবহার করে ডায়নামিক কনফিগারেশন ফাইল তৈরি করা যায়।

tests/:

  • এই ডিরেক্টরিতে টেস্ট ফাইল এবং ইনভেন্টরি ফাইল সংরক্ষণ করা হয়, যা রোলের কার্যকারিতা পরীক্ষা করার জন্য ব্যবহৃত হয়।

vars/:

  • এই ডিরেক্টরিতে রোলের ভ্যারিয়েবল সংরক্ষিত থাকে।
  • main.yml ফাইলে রোলের জন্য ব্যবহৃত ভ্যারিয়েবলগুলো উল্লেখ করা হয়। এটি defaults এর চেয়ে বেশি প্রাধান্য পায়।

README.md:

  • এই ফাইলটি রোল সম্পর্কে তথ্য দেয়, যেমন রোল কীভাবে কাজ করে, কী কী ভ্যারিয়েবল রয়েছে, এবং কীভাবে ব্যবহার করা উচিত। এটি রোল ডকুমেন্টেশনের জন্য ব্যবহৃত হয়।

উদাহরণ রোল ডিরেক্টরি স্ট্রাকচার

নিচে একটি উদাহরণ রোলের ডিরেক্টরি স্ট্রাকচার দেয়া হলো, যেখানে একটি webserver রোল তৈরি করা হয়েছে:

 

roles/
└── webserver/
    ├── defaults/
    │   └── main.yml
    ├── files/
    │   └── httpd.conf
    ├── handlers/
    │   └── main.yml
    ├── meta/
    │   └── main.yml
    ├── tasks/
    │   └── main.yml
    ├── templates/
    │   └── vhost.conf.j2
    ├── tests/
    │   ├── inventory
    │   └── test.yml
    ├── vars/
    │   └── main.yml
    └── README.md

এই উদাহরণে:

  • files/ ডিরেক্টরিতে httpd.conf নামের একটি কনফিগারেশন ফাইল আছে।
  • templates/ ডিরেক্টরিতে vhost.conf.j2 নামের একটি টেম্পলেট আছে।
  • tasks/, handlers/, defaults/, এবং vars/ ডিরেক্টরিতে যথাক্রমে টাস্ক, হ্যান্ডলার, ডিফল্ট ভ্যারিয়েবল, এবং সাধারণ ভ্যারিয়েবলগুলো সংরক্ষণ করা হয়েছে।

সারাংশ

Ansible রোলের ডিরেক্টরি স্ট্রাকচার একটি স্ট্যান্ডার্ড কাঠামো অনুসরণ করে, যা রোল ব্যবহারের সময় সহজে এবং সুসংগঠিতভাবে ব্যবহৃত হয়। এই কাঠামোটি মেনে চলার ফলে রোল তৈরি ও ব্যবস্থাপনা করা সহজ হয় এবং প্লেবুক আরও পুনঃব্যবহারযোগ্য হয়।

Galaxy ব্যবহার করে রোল ইমপোর্ট করা

Ansible Galaxy হলো একটি রেপোজিটরি বা মার্কেটপ্লেস যেখানে রেডি-মেড রোল পাওয়া যায়, যা আপনি আপনার প্রোজেক্টে সহজেই ব্যবহার করতে পারেন। Ansible Galaxy এর মাধ্যমে আপনি প্রি-বিল্ট রোলগুলো ইমপোর্ট, ম্যানেজ এবং শেয়ার করতে পারেন। এটি Ansible রোলগুলির জন্য একটি কেন্দ্রস্থল, যেখানে আপনি বিভিন্ন ডেভেলপারদের তৈরি করা রোলগুলো খুঁজে এবং ডাউনলোড করতে পারেন।

Ansible Galaxy থেকে রোল ইমপোর্ট করার ধাপসমূহ

Ansible Galaxy থেকে রোল ইমপোর্ট করা খুব সহজ। চলুন, ধাপে ধাপে দেখি কীভাবে এটি করা যায়।

ধাপ ১: Ansible Galaxy থেকে রোল সার্চ করা

আপনি কমান্ড লাইন বা ওয়েবসাইটের মাধ্যমে গ্যালাক্সি রোল সার্চ করতে পারেন।

ওয়েবসাইটের মাধ্যমে:

  • Ansible Galaxy এর ওয়েবসাইট (https://galaxy.ansible.com) এ যান।
  • আপনার প্রয়োজন অনুযায়ী রোল সার্চ করুন, যেমন nginx, mysql ইত্যাদি।
  • পছন্দমত রোল নির্বাচন করে ডিটেইলস দেখে নিন।

কমান্ড লাইনের মাধ্যমে:

  • নিচের কমান্ডটি ব্যবহার করে রোল সার্চ করতে পারেন:
ansible-galaxy search nginx
  • এটি nginx সম্পর্কিত রোলগুলির একটি তালিকা দেখাবে।

ধাপ ২: রোল ইমপোর্ট করা

একবার আপনি রোলটি নির্বাচন করে নিলে, সেটি ইনস্টল করতে ansible-galaxy install কমান্ড ব্যবহার করতে হবে।

নিচের ফরম্যাটটি ব্যবহার করে রোল ইমপোর্ট করুন:

ansible-galaxy install .

উদাহরণ:

ansible-galaxy install geerlingguy.nginx

এখানে geerlingguy হলো নেমস্পেস এবং nginx হলো রোলের নাম। এই কমান্ডটি রোলটি ডাউনলোড করে আপনার সিস্টেমে ইনস্টল করবে।

রোলটি সাধারণত ~/.ansible/roles ডিরেক্টরিতে ইনস্টল হবে, বা যদি আপনি আপনার প্রোজেক্টের ডিরেক্টরিতে ইমপোর্ট করতে চান, তাহলে -p ফ্ল্যাগ দিয়ে কাস্টম লোকেশন উল্লেখ করতে পারেন:

ansible-galaxy install geerlingguy.nginx -p ./roles/

ধাপ ৩: প্লেবুকে রোল ব্যবহার করা

ইমপোর্ট করা রোল আপনার প্লেবুকে ব্যবহারের জন্য প্রস্তুত। একটি প্লেবুকের মধ্যে রোল ব্যবহার করতে নিচের মত ফরম্যাট ফলো করুন:

---
- name: Deploy Nginx using a role from Galaxy
  hosts: webservers
  become: yes
  roles:
    - geerlingguy.nginx

এখানে geerlingguy.nginx রোলটি প্লেবুকে অন্তর্ভুক্ত করা হয়েছে। এটি ইনস্টল করা রোল ব্যবহার করে আপনার webservers হোস্টে Nginx কনফিগার করবে।

ধাপ ৪: রোল আপডেট করা (Optional)

কোনো রোল আপডেট করতে চাইলে, --force ফ্ল্যাগ ব্যবহার করে ইন্সটলেশন কমান্ড পুনরায় চালান:

 

ansible-galaxy install geerlingguy.nginx --force

এটি পূর্বে ইন্সটল করা রোলকে আপডেট করে দেবে।

ধাপ ৫: প্রয়োজনীয় ডিপেন্ডেন্সি চেক করা

কিছু রোলের ডিপেন্ডেন্সি থাকতে পারে যা অন্য রোল বা মডিউলের উপর নির্ভর করে। রোল ডাউনলোড করার পর ডিপেন্ডেন্সিগুলো চেক করতে এবং ম্যানেজ করতে:

  • meta/main.yml ফাইলে ডিপেন্ডেন্সির তালিকা থাকে।
  • আপনি নিজে থেকে রোল ডকুমেন্টেশনে ডিপেন্ডেন্সিগুলো দেখে ইনস্টল করতে পারেন।

সংক্ষেপে Ansible Galaxy থেকে রোল ইমপোর্ট করার স্টেপ

  1. রোল সার্চ করুন: গ্যালাক্সি ওয়েবসাইট বা কমান্ড লাইন দিয়ে।
  2. রোল ইন্সটল করুন: ansible-galaxy install <namespace>.<role_name> কমান্ড দিয়ে।
  3. রোল ব্যবহার করুন: প্লেবুকে roles: সেকশন ব্যবহার করে।
  4. রোল আপডেট করুন: --force ফ্ল্যাগ ব্যবহার করে।
  5. ডিপেন্ডেন্সি ম্যানেজ করুন: রোলের ডকুমেন্টেশন অনুযায়ী।

একটি পূর্ণ উদাহরণ

 

# সার্চ কমান্ড
ansible-galaxy search nginx

# ইনস্টল কমান্ড
ansible-galaxy install geerlingguy.nginx

# ইনস্টল লোকেশন চেক
ansible-galaxy list

# প্লেবুক তৈরি
nano deploy_nginx.yml

deploy_nginx.yml ফাইলের কন্টেন্ট:

 

---
- name: Deploy Nginx
  hosts: webservers
  become: yes
  roles:
    - geerlingguy.nginx

Ansible Galaxy এর সুবিধা

  • রিইউজেবিলিটি: আপনি প্রি-বিল্ট রোলগুলো সহজে ব্যবহার করতে পারেন।
  • স্ট্যান্ডার্ড স্ট্রাকচার: গ্যালাক্সির রোলগুলো সাধারণত ভালোভাবে স্ট্রাকচার্ড এবং ডকুমেন্টেড থাকে।
  • ডিপেন্ডেন্সি ম্যানেজমেন্ট: সহজেই ডিপেন্ডেন্সি ম্যানেজ করা যায়।
  • টাইম সেভিং: নতুন করে কোড লেখার সময় বাঁচে এবং ডেভেলপমেন্ট দ্রুত করা যায়।

এইভাবে Ansible Galaxy ব্যবহার করে আপনি সহজে রোল ইমপোর্ট করতে পারেন এবং আপনার প্লেবুকে তা ব্যবহার করে দ্রুত এবং কার্যকরীভাবে কাজ সম্পন্ন করতে পারেন।

 

কাস্টম রোল তৈরি করা

Ansible এ কাস্টম রোল তৈরি করা হলো একটি ভালো প্র্যাকটিস, যা আপনার কোডকে সংগঠিত, পুনরায় ব্যবহারযোগ্য, এবং মডুলার করে তোলে। কাস্টম রোল তৈরি করলে আপনি আপনার প্রয়োজন অনুযায়ী নির্দিষ্ট কনফিগারেশন, টাস্ক, এবং অন্যান্য উপাদানগুলো সাজাতে পারেন।

কাস্টম রোল তৈরি করার ধাপ

Ansible এ কাস্টম রোল তৈরি করতে কয়েকটি ধাপ অনুসরণ করতে হয়। নিচে একটি স্টেপ-বাই-স্টেপ গাইড দেয়া হলো।

ধাপ ১: রোল তৈরি করা

Ansible এ রোল তৈরি করতে ansible-galaxy init কমান্ড ব্যবহার করতে পারেন। এটি স্বয়ংক্রিয়ভাবে রোলের জন্য একটি স্ট্যান্ডার্ড ডিরেক্টরি স্ট্রাকচার তৈরি করবে।

ansible-galaxy init my_custom_role

এটি my_custom_role নামে একটি ডিরেক্টরি তৈরি করবে, যার মধ্যে প্রয়োজনীয় ফোল্ডার এবং ফাইল থাকবে। উদাহরণস্বরূপ:

my_custom_role/
├── defaults/
│   └── main.yml
├── files/
├── handlers/
│   └── main.yml
├── meta/
│   └── main.yml
├── tasks/
│   └── main.yml
├── templates/
├── vars/
│   └── main.yml
└── README.md

ধাপ ২: টাস্ক ডিফাইন করা (tasks/main.yml)

প্রথমে tasks/main.yml ফাইলে আপনার মূল টাস্কগুলো লিখতে হবে। উদাহরণস্বরূপ, আমরা এখানে একটি Nginx ইনস্টল এবং কনফিগার করার টাস্ক তৈরি করব:

 

# my_custom_role/tasks/main.yml
---
- name: Install Nginx
  apt:
    name: nginx
    state: present
  notify: Restart Nginx

- name: Copy Nginx configuration file
  template:
    src: nginx.conf.j2
    dest: /etc/nginx/nginx.conf
  notify: Reload Nginx

এই টাস্কগুলো Nginx ইনস্টল করবে এবং একটি কনফিগারেশন ফাইল কপি করবে। আমরা দুটি হ্যান্ডলারও ব্যবহার করছি: Restart Nginx এবং Reload Nginx

ধাপ ৩: হ্যান্ডলার তৈরি করা (handlers/main.yml)

হ্যান্ডলারগুলো নির্দিষ্ট টাস্ক বা কাজ সম্পন্ন হলে রান হয়। এখন হ্যান্ডলার তৈরি করা যাক:

 

# my_custom_role/handlers/main.yml
---
- name: Restart Nginx
  service:
    name: nginx
    state: restarted
    enabled: yes

- name: Reload Nginx
  service:
    name: nginx
    state: reloaded

এই হ্যান্ডলারগুলো Nginx সার্ভিস রিস্টার্ট এবং রিলোড করার জন্য ব্যবহৃত হবে।

ধাপ ৪: ভ্যারিয়েবল সেট করা (defaults/main.yml)

defaults ফোল্ডারে ডিফল্ট ভ্যারিয়েবল সংরক্ষণ করা হয়, যা আপনি প্লেবুকে ওভাররাইড করতে পারবেন। উদাহরণস্বরূপ:

 

# my_custom_role/defaults/main.yml
---
nginx_port: 80
nginx_user: www-data

ধাপ ৫: টেমপ্লেট তৈরি করা (templates/nginx.conf.j2)

templates ফোল্ডারে আপনি Jinja2 টেমপ্লেট ব্যবহার করে কনফিগারেশন ফাইল তৈরি করতে পারেন। উদাহরণস্বরূপ, nginx.conf.j2 নামে একটি টেমপ্লেট তৈরি করা যাক:

# my_custom_role/templates/nginx.conf.j2
server {
    listen {{ nginx_port }};
    server_name localhost;

    location / {
        root /var/www/html;
        index index.html index.htm;
    }
}

এখানে আমরা {{ nginx_port }} নামে একটি ভ্যারিয়েবল ব্যবহার করেছি, যা defaults বা vars ফোল্ডার থেকে মান নিতে পারে।

ধাপ ৬: ভ্যারিয়েবল ডিফাইন করা (প্রয়োজনে) (vars/main.yml)

আপনি যদি অতিরিক্ত বা নির্দিষ্ট ভ্যারিয়েবল ব্যবহার করতে চান, তাহলে vars/main.yml ফাইলে সেগুলো সংরক্ষণ করতে পারেন।

 

# my_custom_role/vars/main.yml
---
nginx_config_file: /etc/nginx/nginx.conf

ধাপ ৭: মেটাডাটা সেট করা (meta/main.yml)

রোলের ডিপেন্ডেন্সি এবং মেটাডাটা meta/main.yml ফাইলে উল্লেখ করা হয়। যদি আপনার রোল অন্য কোনো রোলের উপর নির্ভরশীল হয়, তাহলে আপনি তা এখানে উল্লেখ করতে পারেন:

 

# my_custom_role/meta/main.yml
---
dependencies:
  - { role: common, some_variable: some_value }

ধাপ ৮: প্লেবুকে রোল অন্তর্ভুক্ত করা

রোল তৈরি এবং কনফিগার করার পর এটি আপনার প্লেবুকে ব্যবহার করা যায়:

 

---
- name: Deploy Nginx server using custom role
  hosts: webservers
  become: yes
  roles:
    - my_custom_role

ধাপ ৯: রোল টেস্ট করা

রোল তৈরি করার পর, আপনার প্লেবুক চালিয়ে এটি টেস্ট করতে পারেন:

 

ansible-playbook -i inventory deploy_nginx.yml

কাস্টম রোল তৈরি করার সুবিধা

  • মডুলারিটি: প্লেবুকের কোডকে ছোট ছোট অংশে ভাগ করে কাজকে সুসংগঠিত করা।
  • রিইউজেবিলিটি: একবার একটি রোল তৈরি হলে, সেটি বিভিন্ন প্লেবুকে বা প্রোজেক্টে পুনরায় ব্যবহার করা যায়।
  • সহজ রক্ষণাবেক্ষণ: রোলগুলোর মাধ্যমে কোড সহজে সংরক্ষণ এবং রক্ষণাবেক্ষণ করা যায়।
  • স্কেলেবিলিটি: বড় স্কেলে প্লেবুক এবং কনফিগারেশন ব্যবস্থাপনা করা সহজ হয়।

সংক্ষেপে

  • ansible-galaxy init দিয়ে রোল তৈরি করুন।
  • টাস্ক, হ্যান্ডলার, ভ্যারিয়েবল, এবং টেমপ্লেটগুলো যথাযথ ডিরেক্টরিতে সাজান।
  • আপনার প্লেবুকে রোল ইমপোর্ট করুন এবং টেস্ট করুন।

এইভাবে কাস্টম রোল তৈরি করে আপনি Ansible প্লেবুকগুলোকে আরও ফ্লেক্সিবল, মডুলার, এবং পুনরায় ব্যবহারযোগ্য করতে পারবেন।

Content added || updated By
Promotion